## **Amendments to the Claims:**

This listing of claims will replace all prior versions, and listings of claims in the application:

## **Listing of Claims:**

| 1 | 1. (Previously presented): A method for classifying received network data                       |
|---|-------------------------------------------------------------------------------------------------|
| 2 | comprising:                                                                                     |
| 3 | providing a language definition; and                                                            |
| 4 | processing incoming network data with said language definition in accordance                    |
| 5 | with a formal language processing technique including scanning said network data using lexical  |
| 6 | token scanning according to said language definition, wherein said network data is treated as a |
| 7 | stream of input bytes, said network data being organized into data packets, said scanning       |
| 8 | resulting in the identification of a data packet as belonging to one of a plurality of classes. |
| 1 | 2. (Original): The method of claim 1 wherein said scanning includes                             |
| 2 | identifying an arithmetic operation and performing said arithmetic operation.                   |
| 1 | 3. (Original): The method of claim 1 wherein said scanning includes                             |
| 2 | identifying a skip operation and in response thereto skipping over one or more subsequent input |
| 3 | bytes.                                                                                          |
| 1 | 4. (Original): The method of claim 1 wherein said lexical scanning includes                     |
| 2 | providing a set of regular expressions, each regular expression having an associated class      |
| 3 | identifier.                                                                                     |
| 1 | 5. (Original): The method of claim 1 further including providing a                              |
| 2 | deterministic finite automaton (DFA) comprising plural states, said step of scanning including  |
| 3 | recognizing data packets using said DFA including transitioning from one state to another.      |
| ĺ | 6. (Original): The method of claim 5 wherein said data packets are variable                     |
| 2 | length data nackets                                                                             |

1

2

3

4

7

8

9

- 7. (Original): The method of claim 5 wherein said DFA is defined by a set
  2 of regular expressions.

  8. (Original): The method of claim 7 further including generating a grammar
- tree data structure representative of said regular expression, producing a non-deterministic finite automaton (NFA) from said grammar tree data structure, and converting said NFA to produce said DFA.
- 9. (Original): The method of claim 5 wherein some of said states include one or more associated computer instructions and wherein said computer instructions are executed in connection with transitioning to a state.
  - 10. (Original): The method of claim 9 wherein some of said states further include a skip instruction.
- 1 11. (Currently amended): In a network data switching device, a method for classifying data packets comprising steps of:
  - providing a language definition in the form of one or more regular expressions, each having an associated class identifier;
- receiving plural data packets, each having a length not necessarily equal to one another; and
  - for each data packet, processing it-said data packet in accordance with a formal language processing technique including determining a matching regular expression from among said regular expressions that matches said data packet, wherein said each data packet is classified according to the class identifier associated with said matching regular expression.
- 1 12. (Original): The method of claim 11 wherein said data packets comprise a data stream and said determining includes lexically scanning said data stream.
- 1 13. (Original): The method of claim 11 wherein said regular expressions are represented by a deterministic finite automaton (DFA).

(Original): The method of claim 13 wherein said DFA is in compressed 1 14. 2 form. 15. (Original): The method of claim 11 further including compiling said 1 2 regular expressions to produce said DFA. 16. (Original): The method of claim 15 wherein said compiling produces a 1 2 non-deterministic finite automaton (NFA) as intermediate data structure, said compiling further 3 includes converting said NFA to produce said DFA. 17. (Original): The method of claim 16 further including reducing said DFA 1 to a compressed form. 2 1 18. (Original): The method of claim 11 wherein said data packet comprises plural bytes, and said determining includes detecting an operator indicating a number of bytes to 2 3 be skipped. 1 19. (Original): The method of claim 18 wherein said number is specified by 2 the value of a current input byte. 1 20. (Original): The method of claim 18 wherein said number is specified in a 2 register. 1 21. (Original): The method of claim 18 wherein said determining further 2 includes detecting an operator indicating a value to be saved in a register. 22. (Original): The method of claim 21 wherein said determining further 1 includes detecting an operator indicating a logical or mathematical operation to be performed on 2 3 the contents of said register.

| 1  |                | 23.       | (Currently amended): In a data packet receiving and forwarding device, a       |
|----|----------------|-----------|--------------------------------------------------------------------------------|
| 2  | method for cl  | assifyin  | g received data packets comprising a stream of data, said method               |
| 3  | comprising st  | eps of:   | ·                                                                              |
| 4  |                | receiv    | ing a description of classification rules in the form of a classification      |
| 5  | language defi  | nition;   |                                                                                |
| 6  |                | compi     | ling said classification language definition to produce a deterministic finite |
| 7  | automaton (D   | FA) co    | mprising plural states;                                                        |
| 8  |                | config    | uring a programmable hardware packet classifier with said DFA; and             |
| 9  |                | receiv    | ing said data stream and processing it said data stream in accordance with a   |
| 10 | formal langua  | ige proc  | essing technique including scanning said data stream with said hardware        |
| 11 | packet classif | ier to cl | assify said received data packets.                                             |
| 1  |                | 24.       | (Original): The method of claim 23 wherein said compiling includes             |
| 2  | aggariating an |           |                                                                                |
| 2  | associating at | immetic   | e and logic instructions with some of said states.                             |
| 1  |                | 25.       | (Original): The method of claim 23 wherein said classification language        |
| 2  | includes regul | lar expr  | essions.                                                                       |
|    |                | 26        |                                                                                |
| 1  |                | 26.       | (Original): The method of claim 25 wherein said regular expressions            |
| 2  | include arithn | netic an  | d logic operations.                                                            |
| 1  |                | 27.       | (Original): The method of claim 26 wherein said regular expressions            |
| 2  | further includ | e skip o  | perations.                                                                     |
|    |                |           |                                                                                |
| 1  |                | 28.       | (Original): The method of claim 27 wherein said regular expressions            |
| 2  | further includ | e data s  | torage operations.                                                             |
| 1  |                | 29.       | (Original): The method of claim 23 wherein said DFA is in compressed           |
| 2  | format.        |           |                                                                                |
|    |                |           |                                                                                |

| 1  | 30. (Previously presented): The method of claim 23 further including:                                 |  |  |  |  |
|----|-------------------------------------------------------------------------------------------------------|--|--|--|--|
| 2  | receiving a second description of classification rules in the form of a second                        |  |  |  |  |
| 3  | classification language definition;                                                                   |  |  |  |  |
| 4  | compiling said second classification language definition to produce a second                          |  |  |  |  |
| 5  | DFA;                                                                                                  |  |  |  |  |
| 6  | configuring a programmable hardware packet classifier with said second DFA;                           |  |  |  |  |
| 7  | and                                                                                                   |  |  |  |  |
| 8  | applying said data stream to said hardware packet classifier to classify said                         |  |  |  |  |
| 9  | received data packets,                                                                                |  |  |  |  |
| 10 | wherein said data packets are classified according to said second classification                      |  |  |  |  |
| 11 | rules, thereby facilitating changing packetizing policies in said data packet routing device.         |  |  |  |  |
| 1  | 31. (Currently amended): A network data packet classifier comprising:                                 |  |  |  |  |
| 2  | an input port for receiving network data packets comprising a stream of data;                         |  |  |  |  |
| 3  | a memory assemblage configured with data representing a deterministic finite                          |  |  |  |  |
| 4  | automaton (DFA), said DFA representing plural regular expressions according to a language             |  |  |  |  |
| 5  | definition; and                                                                                       |  |  |  |  |
| 6  | decompression logic operatively coupled to said memory assemblage and                                 |  |  |  |  |
| 7  | configured to process said stream of data using said language definition in accordance with a         |  |  |  |  |
| 8  | formal language processing technique including scanning said stream of data with said DFA to          |  |  |  |  |
| 9  | find a matching one of said regular expressions,                                                      |  |  |  |  |
| 10 | said regular expressions having corresponding class identifiers,                                      |  |  |  |  |
| 11 | wherein each of said network data packets is associated with the class identifier of                  |  |  |  |  |
| 12 | said regular expression that matches itsaid each network data packet.                                 |  |  |  |  |
| 1  | 32. (Original): The classifier of claim 31 wherein some of said regular                               |  |  |  |  |
| 2  | expressions include arithmetic instructions and logic instructions, said memory assemblage            |  |  |  |  |
| 3  | further configured to contain said instructions, the classifier further including an arithmetic logic |  |  |  |  |
| 4  | unit operatively coupled to said decompression logic and configured to execute said instructions.     |  |  |  |  |

5

33. (Original): The classifier of claim 32 further including at least one register 1 2 operatively coupled to said arithmetic logic unit, said arithmetic logic unit further configured to 3 store data into said register in response to a save instruction. 1 34. (Original): The classifier of claim 32 further including skip logic operatively coupled to said logic component and configured to skip over an amount of data in 2 3 response a skip instruction. 1 35. (Original): The classifier of claim 31 wherein said network data packets 2 can vary from one packet to another. (Original): The classifier of claim 31 wherein said DFA is in compressed 1 36. 2 form. 37. (Original): The classifier of claim 36 wherein said DFA comprises plural 1 2 non-default states and plural default states, and said memory assemblage comprises a base memory, a next-state memory, and a default-state memory; said base memory configured to 3 contain address locations of said next-state memory, said next-state memory representing all of 4 said non-default states, said default-state memory representing all of said default states. 5 1 38. (Original): The classifier of claim 37 wherein said memories are random 2 access memories. 1 39. (Original): The classifier of claim 37 wherein said memories are read-2 only memories. 1 40. (Previously presented): A network data packet classifier comprising: 2 an input configured to provide a data packet comprising a stream of data; 3 a first system of memory configured with data representing a deterministic finite 4 automaton (DFA), said DFA defined in accordance with a language definition and comprising

plural states including an initial state and plural terminating states;

6

7

8

9

10

11

12

1

2

3

4

5

1

2

- a system of logic circuits operatively coupled to said first system of memory and to said input, and configured to process said data stream using said language definition in accordance with a formal language processing technique including a step to lexically scan said data stream with said DFA to produce a reached terminating state; and a second system of memory configured with data representing a class index corresponding to each of said terminating states and configured to output a class index in response to the production of said reached terminating state.
- 41. (Original): The classifier of claim 40 further including a third system of memory configured to contain current state information for plural input channels, said system of logic circuits operatively coupled to said third system of memory to initialize said DFA in accordance with current state information corresponding to the input channel associated with said data packet.
- 1 42. (Original): The classifier of claim 40 wherein some of said states have 2 one or more associated instructions, the classifier further including an arithmetic logic unit 3 operatively coupled to said system of logic circuits and configured to execute said instructions.
  - 43. (Original): The classifier of claim 42 further including at least one register operatively coupled to said arithmetic logic unit, said arithmetic logic unit further configured to store data into said register in response to a save instruction.
- 1 44. (Original): The classifier of claim 42 further including skip logic 2 operatively coupled to said logic component and configured to skip over an amount of data in 3 response a skip instruction.
- 1 45. (Original): The classifier of claim 40 wherein said stream of data is a 2 stream of bytes.
- 1 46. (Original): The classifier of claim 40 wherein said data packets vary from 2 one packet to another.

| 1 | 47. (Currently amended): A network packet classifier comprising:                                 |  |  |  |  |
|---|--------------------------------------------------------------------------------------------------|--|--|--|--|
| 2 | means for receiving an incoming network packet;                                                  |  |  |  |  |
| 3 | means for processing said network packet in accordance using a language                          |  |  |  |  |
| 4 | definition in accordance with a formal language processing technique including classifying said  |  |  |  |  |
| 5 | network packet by matching the pattern of its constituent data of said network packet against    |  |  |  |  |
| 6 | plural regular expressions, each regular expression having a corresponding class identifier; and |  |  |  |  |
| 7 | means for outputting a class identifier of the regular expression which matches                  |  |  |  |  |
| 8 | said network packet.                                                                             |  |  |  |  |
| 1 | 48. (Original): The classifier of claim 47 wherein said means for classifying                    |  |  |  |  |
| 2 | includes a memory component configured with data to represent a deterministic finite automaton   |  |  |  |  |
| 3 | (DFA).                                                                                           |  |  |  |  |
| 1 | 49. (Original): The classifier of claim 48 wherein said means for outputting                     |  |  |  |  |
| 2 | includes a second memory component configured with said class identifiers.                       |  |  |  |  |
| 1 | 50. (Original): The classifier of claim 47 wherein said regular expressions                      |  |  |  |  |
| 2 | include arithmetic specifiers and said means for classifying includes an arithmetic logic unit   |  |  |  |  |
| 3 | configured to perform operations in accordance with said arithmetic specifiers.                  |  |  |  |  |
| 1 | 51. (Currently amended): A network packet classifier comprising:                                 |  |  |  |  |
| 2 | a dual-ported memory component;                                                                  |  |  |  |  |
| 3 | first classification logic operatively coupled to a first port of said dual-ported               |  |  |  |  |
| 4 | memory component and having a first input for receiving a data stream; and                       |  |  |  |  |
| 5 | second classification logic operatively coupled to a second port of said dual-                   |  |  |  |  |
| 6 | ported memory component and having a second input for receiving a data stream,                   |  |  |  |  |
| 7 | said memory component configured to contain a deterministic finite automaton                     |  |  |  |  |
| 8 | (DFA) representative of a language definition and comprising plural states,                      |  |  |  |  |
| 9 | said DFA representing plural regular expressions for matching data packets,                      |  |  |  |  |

11

12

- 10 said first and second classification logic each configured to process its an associated data stream using said language definition according to a formal language processing technique including a step to scan its said associated data stream using said DFA to identify data packets contained therein and to classify identified data packets.
- 1 52. (Original): The classifier of claim 51 wherein said data packets are 2 characterized in being variable in length.
- 1 53. (Original): The classifier of claim 51 wherein said regular expressions include arithmetic and logic operators. 2
- 1 54. (Original): The classifier of claim 51 wherein said regular expressions 2 include a skip operator.